package com.fsm.system.entity.table;

import com.mybatisflex.core.query.QueryColumn;
import com.mybatisflex.core.table.TableDef;


/**
 *  表定义层。
 *
 * @author
 * @since
 */
public class TSystemRoleTable extends TableDef {

    private static final long serialVersionUID = 1L;

    /**
     *
     */
    public static final TSystemRoleTable T_SYSTEM_ROLE = new TSystemRoleTable();

    /**
     * 角色id
     */
    public final QueryColumn ID = new QueryColumn(this, "id");

    /**
     * 角色名称
     */
    public final QueryColumn NAME = new QueryColumn(this, "name");

    /**
     * 是否存在
     */
    public final QueryColumn EXIST = new QueryColumn(this, "exist");

    /**
     * 创建时间
     */
    public final QueryColumn CREATE_TIME = new QueryColumn(this, "create_time");

    /**
     * 修改时间
     */
    public final QueryColumn UPDATE_TIME = new QueryColumn(this, "update_time");

    /**
     * 所有字段。
     */
    public final QueryColumn ALL_COLUMNS = new QueryColumn(this, "*");

    /**
     * 默认字段，不包含逻辑删除或者 large 等字段。
     */
    public final QueryColumn[] DEFAULT_COLUMNS = new QueryColumn[]{ID, NAME, CREATE_TIME, UPDATE_TIME, EXIST};

    public TSystemRoleTable() {
        super("", "t_system_role");
    }

    private TSystemRoleTable(String schema, String name, String alisa) {
        super(schema, name, alisa);
    }

    public TSystemRoleTable as(String alias) {
        String key = getNameWithSchema() + "." + alias;
        return getCache(key, k -> new TSystemRoleTable("", "t_system_role", alias));
    }

}
